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Section 1 

General Information 



1 . 1 INTRODUCTION 



This manual provides the information needed to install and operate 
the SDC-RXV21 floppy disc controller manufactured by Sigma Informa- 
tion Systems, Anaheim, California. The SDC-RXV21 supports one or 
two dual density, single or double sided floppy disc drives. The 
single dual-wide board is software and media compatible with DEC's* 
RXV21/RX02, and features an on-board bootstrap and diskette formatting 
capability. 

The material in this manual is arranged into the following sections: 



Section 1 - GENERAL INFORMATION. This section contains a brief 
description of the SDC-RXV21, its logical track format, recording 
scheme, and a list of specifications. 



Section 2 - INSTALLATION. This section explains the requirements 
and procedures for equipment installation. Alternate jumper 
selectable options and cabling are described. 



Section 3 - OPERATION. This section explains the controller opera- 
tion, including bootstrapping and formatting. 



Section 4 - PROGRAMMING. A description of the SDC-RXV21 control 
registers and programming features is presented to aid the user in 
programming the controller. 



*DEC, LSI-11, and Q bus are registered trademarks of Digital Equip- 
ment Corporation. 
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1.2 GENERAL DESCRIPTION 



The SDC-RXV21 is a dual density floppy disc controller compatible 
with the DEC* KX01/RX02. When connected to a Shugart-type drive, It 
replaces the RXV21 subsystem. The controller provides either single 
density encoding compatible with IBM 3740 devices, or double density 
encoding. The controller: provides 512K bytes of storage on a single 
diskette. When two floppy drives are used, each drive may operate 
at a different density. 

The SDC-RXV21 is a single dual-wide board that plugs directly into 
any standard Q bus slot and interfaces through a 50-conductor ribbon 
cable to a Shugart compatible drive. The controller is factory 
preset for the standard device address 177170 and interrupt vector 
264. The interrupt level is factory preset to level 4. Alternate 
addresses and interrupt vector are Jumper selectable. Features 
include: 

• Transparent firmware bootstrap which automatically boots double 
density diskettes (jumper selectable). 

• Write precompensation to reduce bit shift for greater data inte- 
grity. 

• Power fail protect to inhibit write sequence while the controller 
completes sector currently being written. 

• Provides write current coatrol for tracks greater than 43. 

• Jumper selectable 4-level interrupt priorities compatible with 
LSI-11/23 or LSI-11/2. 



1 . 3 COMPATIBILITY 



The hardware, software and media compatibility with DEC's RXV21 
system is provided to aid the user in data interchange with foreign 
systems. 

HARDWARE . The controller is compatible with the LSI-11, LSI-11/2 
and LSI-11/2 3 CPUs. The single dual-wide board plugs directly into 
any standard LSI-11 backplane. Alternate address selection and a 
4-level device interrupt priority scheme that provides for expanded 
system configurations. Shugart 800/850-compatible drive logic is 
interfaced through a 50-pin ribbon connector. 



1-2 



SOFTWARE . The SDC-RXV21 is completely compatible with DEC's RXV21 
register definition and command protocol. The SDC-RXV21 will operate, 
with no modification, with operating systems and diagnostics designed 
for the RX02. 

MEDIA . Media (either preformatted or blank soft sectored diskettes) 
for the SDC-RXV21 is compatible with the IBM 3740. Recommended media 
are: IBM single or double density or DEC RX01/RX02. 



1.4 LOGICAL TRACK FORMAT 



Figure 1-1 defines o.ich track lormat. The sector header field of 
each sector contains information describing both the sector and track 
number. All fields are recorded in FM except as noted in the follow- 
ing sections. 



1.4.1 Sect or He a der Field 

The header field consists of 7 bytes of information, preceded by a 
field of 6 bytes of "zero" data for synchronization. 

Byte 1 ID ADDRESS MARK . A unique mark consisting of 1 
byte of FE(hex) data with three missing clock- 
transitions using a C7 (hex) clock pattern. This 
mark is decoded by the controller and indicates 
the start of the sector header. 

Byte 2 TRACK ADDRESS . This byte indicates the absolute 
(0~114j}) track address. F^ach sector contains this 
track information to locate its position on one 
of the 77 tracks. 

Byte 3 "ZERO" 

Byte 4 SECTOR AD D RESS . This byte indicates the absolute 
(0-32q) sector address. Each sector contains this 
information to identify its position on the track. 

Byte 5 "ZERO" 



Byte 6,7 CRC . This is the 16-bit cyclic redundancy charac- 
ter and is calculated for each header from the 
first 5 bytes of information. Calculation, using 
the IBM 3740 polynomial, is defined in Section 
1.4.3. 
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128 Bytes FM 
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1 Byte 



0s - 1 Byte 
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FIGURE 1-1: LOGICAL TRACK FORMAT 
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1.A.2 Data Field 

The data field consists of either 131 or 259 bytes of Information 
(depending on recording method) , preceded by 6 bytes of "zero" data 
for synchronization. 

The preamble and data address mark are written in FM. The user data 
and CRC character are written In either FM or modified MFM, depend- 
ing on the formatted diskette density. 

Byte 1 DATA ADDRESS MARK . This byte Is a unique mark con- 
sisting of a data byte with three missing clock 
transitions using a C7 (hex) clock pattern as 
defined in Table 1-1. This byte is written in FM 
and is decoded by the controller to indicate the 
start of the data field, FM vs MFM recording 
method, and deleted data field Indication. 



ADDRESS MARK 


INDICATED DENSITY 


DATA 


INDEX 


N/A 


FC 


ID 


N/A 


FE 


DATA 


FM 


FB 


MFM Modified 


FD 


DELETED 
DATA 


FM 


F8 


MFM Modified 


F9 



TABLE 1-1: ADDRESS MARKS 



■Bytes FM (BYTES 2-129) OR MODIFIELD MFM (BYTES 2-257). 

2-257 This field is recorded in either FM or modified 
MFM. Either 128 or 256 bytes of information can 
be stored, depending on the encoding scheme. 

Bytes CRC . This 16-blt cyclic redundancy character is 
130-131 calculated for each data field from the first 129 

or or 257 bytes of information using the IBM 37AO 
258-259 polynomial as defined in Section 1.4.3. These 

bytes are recorded with the same encoding scheme 
as the data field. 



1.4.3 CRC - Cyclic R edundancy Check 

Each sector header field and data field has a 2-byte (16-bit) CRC 
character which is the remainder that results when dividing the data 
bits [represented as a polynomial M(x)] by a generator polynomial 
G(x). The polynomial used for IBM 3740 is G(x) = x^^ + x^"^ + x^ + 1 , 
Data bits include bytes 1-5 for the sector header, bytes 1-129 for 
an FM data field, and bytes 1-257 for an MFM data field. 
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1.5 RECORDING SCHEME 



Double frequency (FM) and DEC modified Miller code (MFM) recording 
schemes are used by the SDC-RXV21. FM, used for single density 
recording, is compatible with IBM 3740 or DEC RXOl media. Modified 
I'lFM, used for recording double density, is compatible with the RX02 
system. 



1 . 6 SPECIFICATIONS 



Power Requirements; 
Bus Load : 
Priority Level: 

Device Address: 

Interrupt Vector: 

Interface: 

Media: 

Recording Method: 

Bootstrap: 

Cable: 

Temperature : 
Humidity: 



+5VDC at 2.5A (from LSI-11 backplane) 

1 

4-level compatible with LSI-ll/2;3 CPU 
(Selectable alternates) 

177170 (Selectable alternate at 177174) 

264 (Selectable alternate at 270) 

Shugart compatible 

RX01/RX02 compatible 

DEC modified MFM (Double density compatible 
RX02) or optional FM (single density compatible 
with IBM 3740) 

On-board. Initiated when program execution 
starts at 173000. Can be disabled. 

Required standard 50-conductor 3M-type ribbon 
cable. 

CC to 45''C 

10% to 95% non-condensing. 
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Section 2 
Installation 



2.1 CONTROLLER JUMPER CONFIGURATIONS 



The SDC-RXV21 is shipped configured with DEC-standard operating 
parameters as defined in Table 2-1. 



PARAMETER 


SELECTION 


Control Address 


177170 


Vector Address 


26A 


Interrupt 


Level 4 


Firmware Bootstrap 


Enabled 


Write Precompensation 


Enabled 


Write Current Control 


Disabled 


Drive Select 


Single or Double 




Sided 



TABLE 2-1: FACTORY SET PARAMETERS 

Most options are etched to the most often used operation. Etches 
must be cut before alternate Jumpers are inserted. Several of the 
options are selectable by using AMP 530153-2 pin Jumpers or, alter- 
nately, //30 wire wrap. Refer to Figure 2-1 for jumper locations. 

NOTE: Certain Jumpers are dedicated for factory test only. Jumpers 
11-12, 13-14, 19-21 and 20-22 must NOT be removed. Jumper 
17-18 must always be out. 



2.1.1 Device and Vector Address Selection 

The controller is shipped with the DEC standard device and vector 
addresses preset to 177170 and 264 respectively. Any change in 
these addresses requires a change in system software 
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TEST 
(DO NOT 
REMOVE) 

TEST 
(DO NOT 
REMOVE) 



STANDARD 
VECTOR 

STANDARD 
ADDRESS 



interrupj: 
priority 



INTERRUPX 
PRIORITY 




WRITE CURRENT 

DRIVE SELECT 



TEST 
L-^^ALWAYS OUT) 



TEST 
(DO NOT 
REMOVE) 

TEST 
(DO NOT 
REMOVE) 

WRITE 
PRECOMPENSATION 



2^-28 

BOOTSTRAP 



INTERRUPT 
PRIORITY 
INTERRUPT 
PRIORITY 



f 






INTERRUPT 
PRIORITY 



FIGURE 2-1: JUMPER LOCATIONS INDICATING FACTORY SET JUMPERS /ETCHES 
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The alternate device and vector addresses are selectable and are 
defined as 177174 and 270 respectively. These alternate addresses 
are typically used for systems with more than two drives where two 
controllers are required. To configure the second controller for 
address/vector assignments, cut the etch between W23 and W24 ; then 
jumper W24-W26 and W15-W16 as sliown in Table 2-2. 



OPTION 


JUMPERS 


23- 24 


24-26 


15-16 


Standard Device (177170) 
Vector (264) Addresses * 


IN 


OUT 


OUT 


Alternate Device (177174) 
Vector (270) Addresses 


OUT 


IN 


IN 



*Factory Preset 

TABLE 2-2: DEVICE/VECTOR ADDRESS JUMPERS 

2.1.2 Device Interrupt Prio rity 

The SDC-RXV21 supports the 4-level device interrupt priority scheme 
compatible with the LSI-11/23. The controller asserts interrupt 
requests and monitors higher level request lines during interrupt 
arbitration The level 4 request is always asserted by the controller, 
regardless of its priority, to maintain compatibility with the LSI-11 
and LSI-11/2 CPUs. 

The interrupt priority is f.ictory preset to level 4. If an alternate 
interrupt level is desired the following etches must be cut: W39-W40, 
W42-W43, W32-W33, W35-W36, and W45-W46. Refer to Table 2-3 for the 
jumper installation for the desired priority level. 



PRIORITY 

LEVEL 


ASSERT 

LEVEL 


MONITOR 
LEVEL 


JUMPERS 


W32 
W33 


W33 

W34 


W35 
W36 


W36 
W37 


W38 
W39 


W39 
W40 


W41 
W42 


W42 
W43 


W44 
W45 


W45 
W46 


4* 


4 


5,6 


IN 


OUT 


IN 


OUT 


OUT 


IN 


OUT 


IN 


OUT 


IN 


5 


4,5 


6 


IN 


OUT 


OUT 


IN 


IN 


OUT 


OUT 


IN 


OUT 


IN 


6 


4,6 


7 


OUT 
OUT 


EN 


IN 


OUT 


OUT 
IN 


IN 
OUT 


TN 


OUT 


TN 


OUT 
OUT 


7 


4,6,7 


NONE 


IN 


OUT 


IN 


IN 


OUT 


IN 



*Factory Preset 



TABLE 2-3: PRIORITY LEVEL CONFIGURATIONS 
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2.1.3 



Bootstrap 



The controller board contains a transparent firmware bootstrap which 
is Initiated whenever program execution is started at location 
173000, homing both drives to track 0. Track 1, sector 1, of unit 
is then read and diskette density is determined. For single density 
diskettes, sectors 1, 3, 5, and 7 are loaded into memory starting at 
location 0. If the diskette is double density, sectors 1 and 3 are 
loaded. Program execution is then transferred to location 0. 



BOOTSTRAP 


JUMPERS 


W25-W28 


W25-W27 


Enable* 


IN 


OUT 


Disable 


OUT 


IN 



^Factory Jumpered 



TABLE 2-4: BOOTSTRAP CONFIGURATIONS 



NOTE: Only one bootstrap should be enabled in a system for proper 
operation. If a second bootstrap exists in the system, it 
must be disabled before enabling the SDC-RXV21 bootstrap. 



2 .1.4 Write Precompensat ion 

The SDC-RXV21 controller provides hardware write precompensation to 
reduce bit shift. The RXV21 controller is shipped with write pre- 
compensation enabled. It is recommended that, for reliable operation, 
this feature not be disabled. However, if write precompensation must 
be disabled, remove the etch W30-W31 and insert jumper W29-W30 as 
shown in Table 2-5. 



WRITE 
PRECOMPENSATION 


JUMPERS 


W29-W30 


W30-W31 


Enable* 


OUT 


IN 


Disable 


IN 


OUT 



*Factory Jumpered 



TABLE 2-5: WRITE PRECOMPENSATION CONFIGURATIONS 
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2.1.5 Write C urrent Ccmtrol' 

The SDC-RXV21 provides the necessary signal to reduce the write 
current for tracks greater than 43. This signal is available at pin 
2 of the 50-pln ribbon connector. 



Since single sided drives with Shugart-type 800 series interfaces do 
not require a write current signal, the controller is shipped with 
this feature disabled. However, double sided drives with Shugart- 
type 850 series interfaces do support write current control, and 
enabling this feature is recommended for double sided drives. This 
may be accomplished with jumper W5-W6 as shown in Table 2-6. 



*Sliou.ld be enabled for 
double sided drives 



WRITE 
CUIU^KNT 


JUMP I- K 
W5-W6 


Enable* 


IN 


Disable** 


OUT 



**Factory preset 



TABLE: 2-6: WRITE CURRENT CONFT CURAT IONS 



2.1.6 Drive and Side Selection 

The SDC-RXV21 controller has jumper options for both drive and side 
selection. Side select can be disabled, allowing operation on single 
sided drives only. The controller can be configured for either 
single or double sided drives. Jumpering allows one double sided 
drive to be addressed as two drives, where side appears as drive 
and side 1 appears as drive 1. 

The controller, when shipped, is con figured for either single or 
double sided drives. If double sided drives are used, it is recom- 
mended that write current control be enabled. Before selecting 
alternate options etch W2-W4 must be cut and then jumpers Inserted 
as shown in Table 2-7. 



DRIVE/ SIDE SELECT 


JUMPERS 


W1-W2 


W2-W3 


W2-W4 W7-W8 


W9-W10I W7-W9 


Single Sided Drive 


IN 


~ 1 

OUT 


OUT 


IN 


IN 


OUT 


Single or Double 
Sided Drive* 


OUT 


OUT 


IN 


IN 


IN 


OUT 


Double Sided Drive 
Drive = Side 
Drive 1 = Side 1 


OUT 


IN 


OUT 


OUT 


IN 


IN 



*Factory preset 

TABLE 2-7: DRIVE/SIUE CONFIOUIIATIONS 
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2.2 DRIVE CONFIGURATIONS 



For proper operation, the floppy drive(s) must be configured correctly. 
The controller uses radial drive selection and the drive(s) must be 
set up with this in mind. When two drives are used, the first drive 
is denoted and the second drive 1. A particular drive is selected 
and remains selected after a function is complete, thus allowing the 
controller to poll drive status. A separate head load signal is 
provided by the control -er read and write functions on the diskette. 
The "in use" logic of the drive is configured as a function of head 
loading. Since the drives are homed without loading the heads during 
an initialize command, the drive is configured to provide stepper 
motor power independent of head loading. Refer to Table 2-8 for 
Shugart SA800/801, Table 2-9 for Shugart SA850/851, and Table 2-9 for 
Qume Data Trak 8 and YE-Data YD-174 strapping configurations. 



DESCRIPTION 


SHUGART 


DUAL 


DRIVES 


SINGLE 


Lyi-«Jv/l\±l 1 XV/ll 


JUMPER 


DRIVE DRIVE 1 DRIVE 


Drive Select 1 


DSl 


IN 


OUT 


IN 


Drive Select 2 


DS2 


OUT 


IN 


OUT 


Drive Select 3 


DS3 


OUT 


OUT 


OUT 


Drive Select 4 


DS4 


OUT 


OUT 


OUT 


Radial Head Loading Option 


A 


IN 


IN 


IN 


Radial Head Loading Option 


B 


IN 


IN 


IN 


Head Load Option 


C 


IN 


IN 


IN 


In Use Option 


D 


OUT 


OUT 


OUT 


Radial Head Loading Option 


X 


OUT 


OUT 


OUT 


Inhibit Write When Protect 


WP 


IN 


IN 


IN 


Allow Write When Protect 


NP 


OUT 


OUT 


OUT 


Stepper Power from Drive Select 


DS 


IN 


IN 


IN 


Stepper Power from Head Load 


HL 


OUT 


OUT 


OUT 


In Use from Drive Select 


Z 


OUT 


OUT 


OUT 


In Use from Head Load 


Y 


IN 


IN 


IN 


Ready Output 


R 


IN 


IN 


IN 


Index Output 


I 


IN 


IN 


IN 


Disk Change Output 


DC 


X 


X 


X 


Sector Output 


S 


X 


X 


X 


Sector Option Disable 


800 


IN 


IN 


IN 


Sector Option Enable 


801 


OUT 


OUT 


OUT 


-5V DC Bias 


L 


IN 


IN 


IN 


Termination HL 


Tl 


OUT 


IN 


IN 


Termination Drive Select 


T2 


IN 


IN 


IN 


Termination Direction 


T3 


OUT 


IN 


IN 


Termination Step 


T4 


OUT 


IN 


IN 


Termination Write Data 


T5 


OUT 


IN 


IN 


Termination Write Gate 


T6 


OUT 


IN 


IN 


TABLE 2-8: CONFIGURATIONS FOR SHU 


GART SA80 


0/801 IN 


TERFACE 


DRIVES 
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TRACE 
DESI6 



DESCRIPTION 



DUAL DRIVES 
DR!3 iDRl 



SINGLE 
DR 



SE Termination for multiplexed standard input 

DSl Drive select 1 input pin 
DS2 (Drive s elect 2 input pin 
1B,2b |3B,4B~| Side select option using drive select 
RR I Radial ready 

RI Radial index and sector 

R* Option shunt for ready output 

2S Two-sided status output 
850/51 Sector option enable 

I* Index output 

S* Sector output 

DC Disk change option 

HL* Stepper power from head load 

DS Stepper power from drive select 

WP Inhibit write when write protected 

NP Allow write when write protected 

D Alternate input - in use 

M Multi -media option 

DL Door lock latch option 

A,B* Radial head load 

X* Radial head load 

C Alternate input - head load 

Z* In use from drive select 

Y In use from head load 

51 Side select option using direction select 

52 Standard side select input 

53 Side select option using drive select 
TS,FS Data separation option select 

IW Write current switch 

RS Ready standard 

RM Ready modified 

HLL Head load latch 

IT In use terminator 

HI Head load or in use to in use circuit 

F Remove for MFM encoding 

AF Install for FM or MFM encoding 

NF Install for M2FM encoding 

*Shunt 4F 



IN 


OUT 


IN 


IN 


OUT 


IN 


OUT 


IN 


N/A 


OUT 


OUT 


OUT 


IN 


IN 


IN 


IN 


IN 


IN 


IN 


IN 


IN 


IN 


IN 


IN 


IN 


IN 


IN 


IN 


IN 


IN 


OUT 


OUT 


OUT 


OUT 


OUT 


OUT 


OUT 


OUT 


OUT 


IN 


IN 


IN 


IN 


IN 


IN 


OUT 


OUT 


OUT 


OUT 


OUT 


OUT 


IN 


IN 


IN 


OUT 


OUT 


OUT 


IN 


IN 


IN 


OUT 


OUT 


OUT 


IN 


IN 


IN 


OUT 


OUT 


OUT 


IN 


IN 


IN 


OUT 


OUT 


OUT 


IN 


IN 


IN 


OUT 


OUT 


OUT 


OUT 


OUT 


OUT 


IN 


IN 


IN 


IN 


IN 


IN 


OUT 


OUT 


OUT 


OUT 


OUT 


OUT 


OUT 


OUT 


OUT 


OUT 


OUT 


OUT 


OUT 


OUT 


OUT 


IN 


IN 


IN 


OUT 


OUT 


OUT 



TABLE 2-9: CONFIGURATIONS FOR SHUGART SA850/851 INTERFACE DRIVES 

NOTE: For SA850/851 drives, a 16-pin programmable shunt, location 4F 
(P/N 15658), is provided for the eight most commonly used cut track 
options. These traces are usually shorted as shipped from the factory. 
The traces can be opened as follows: 



Jumper Z 


Open Pin 


1 to Pin 


16 


Jumper HL 


Open 


Pin 2 to Pin 


15 


Jumper A 


Open Pin 


3 to Pin 


14 


Jumper B 


Open 


Pin 4 to Pin 


13 


Jumper X 


Open Pin 


5 to Pin 


12 


Jumper I 


Open 


Pin 6 to Pin 


11 


Jumper R 


Open Pin 


7 to Pin 


10 


Jumper S 


Open 


Pin 8 to Pin 


9 
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DESCRIPTION 



Drive Select 1 
Drive Select 2 
Drive Select 3 
Drive Select A 
Radial Head Load Option 
Radial Head Load Option 
Radial Head Load Option 
In Use from Drive Select 
Stepper Power from Head Load 
Ready Alternate Output Pad 
Index Alternate Output Pad 
Alternate Input Head Load 
Alternate Input in Use 
Alternate Output Disc Change 
Alternate Output 2-Sided Disc Status 
Stepper Power from Drive Select 
In Use from Head Load 
Door Lock Latch 
Radial Ready 
Radial Index 

Inhibit Write when Write Protected 
Allow Write when Write Protected 
Drive Address, Select Pads (up to 
8 Drives) 

Two Headed Drive Select 

Head Select Option 
Head Select Option 
Head Select Option 
Termination Resistor Pack 
Termination Resistor Pack 





QUME 
JUMPER 


DUAL DRIVES 


r 

SINGLE 
DRIVE 




DRIVE 


DRIVE 1 




DSl 


IN 


OUT 


IN 




DS2 


OUT 


IN 


OUT 




DS3 


OUT 


OUT 


OUT 




DS4 


OUT 


OUT 


OUT 




A 


IN 


IN 


IN 




B 


IN 


IN 


IN 




X 


OUT 


OUT 


OUT 




Z 


OUT 


OUT 


OUT 




HL 


OUT 


OUT 


OUT 




R 


IN 


IN 


IN 




I 


IN 


IN 


IN 




C 


IN 


IN 


IN 




D 


OUT 


OUT 


OUT 




DC 


IN 


IN 


IN 


itus 


2S 


IN 


IN 


IN 




DS 


IN 


IN 


IN 




Y 


IN 


IN 


IN 




DL 


OUT 


OUT 


OUT 




RR 


IN 


IN 


IN 




RI 


IN 


IN 


IN 


id 


HP 


IN 


IN 


IN 




NP 


OUT 


OUT 


OUT 


) 


1)1, D2 
^D4,DDS'' 


OUT 


OUT 


OUT 




B1,B2 
^B3,B4'' 


OUT 


OUT 


OUT 




SI 


OUT 


OUT 


OUT 




S2 


IN 


IN 


IN 




S3 


OUT 


OUT 


OUT 




ITM 


OUT 


IN* 


IN 




2TM 


OUT 


IN* 


IN 



*Termination resistor pack must be installed on drive 1 and removed 
from drive on dual floppy systems. On single floppy systems, 
install the termination i-esistor on drive 0. 



TABLE 2-9: CONFIGURATIONS FOR QUME (DATA TRAK 8) AND VE-DATA (YD-174) 

INTERFACE DRIVES 
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2 . 3 CABLING 



An optional 50-conductor ribbon cable connects the controller to a 
Shugart compatible drive. Connect the cable to the 50-pin connector 
located at the top of the controller board, observing the alignment 
of pin 1 as indicated in Figure 2-2. The cable can be purchased from 
an independent source, or the following list of materials (or equiva- 
lent) will aid in the construction of the required cable. 



QTY 



DESCRIPTION 



MFG 



P/N 



1 50-pin controller connector 3M 3425-3000 

2 50-pin drive connectors 3M 3415-0001 
A/R 50 conductor ribbon cable 3M 3365/50 



PIN 1 




DRLVI' URiV 



A 



SI)C-RXV2] 
CONTROLLER 



FIGURE 2-2: DRIVE/CONTROLLER CABLING 
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The connector pins illustrated in Figure 2-3 are compatible with Shugart- 
type 800/850 series interfaces. 





1 


2 










* 


3 


4 








5 


6 








7 


8 




9 


10 










11 


12 








13 


14 








^* 


15 


16 








17 


18 


_^ 








19 


20 






^ 




21 


22 










23 


24 








25 


26 


^^ 


» -«. 




** 


27 


28 








29 


30 








31 


32 








33 


34 






*' 


35 


36 










37 


38 








39 


40 




. ) 






41 


42 






43 


44 








45 


46 








47 


48 








49 


50 









TG43 



TWO SIDED 



SIDE SELECT 



HEAD LOAD 



INDEX 
READY 



DRIVE SELECT 1 
DRIVE "SELECfT 



DIRECTION 


STEP 




WRITE 


DATA 


WRITE 


GATE 


TRACK 00 


WRITE 


PROTECT 



READ DATA 



FIGURE 2-3: CONNECTOR PIN DEFINITIONS 
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2. A CONTROLLER INSTALLATION 



The SDC-RXV21 controller can be installed directly into any Q bus slot 
provided that interrupt and DMA continuity is maintained. These 
signals are daisy chained through the LSI-11 backplane and there 
should be no unused slots between the processor and the floppy control- 
ler. Priority sequences for the backplane can be found in the docu- 
mentation accompanying the LSI-11 system. Note that when two inter- 
rupts of the same priority level are asserted, the device closer to 
the CPU receives the higher priority. 

2.5 INITIAL CHECKOUT 



After the controller jumpers and drive selection have been configured, 
initial checkout is performed using the following procedure. 



NOTE 



The bootstrap must be disabled 
for the following procedure 



Apply AC and DC power to the drive (s). The spindle should begin 
to rotate. The "in use" indicators on both drives should be off. 

Place the RUN/HALT switch on the CPU to the HALT position and turn 
on the processor. An @ character on the terminal signifies that 
console ODT has been entered. First drive 1, then drive 0, will 
step the heads inward 10 tracks; then step the heads outward until 
the home signal is detected. If heads will not load and/or "in-use' 
indicators do not light, check cabling and drive power supplies. 

Place a preformatted scratch diskette in drive 0. 

If the standard address assignment is selected, open the Control 
Status (CS) register using ODT by typing 177170o. The terminal 
will display GOAGAOg the contents of the CS register. Deposit a 
AOOOOg in the CS by typing 40000 {CR). This command will initi- 
alize the controller. First drive 1, then drive will calibrate 
for home position by stepping inward 10 tracks and then outward 
one track at a time until the drive indicates track has been 
reached. After calibration the head on drive is loaded. 
Sector 1 of track 1 is read into the controller buffer, as indi- 
cated by the in-use LED on drive 0. The LED will remain on for a 
short time after the read operation is complete. 
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If, after initializing, the drives do not calibrate or the LED 
does not light, check the cabling and power supplies. 

Reopen the CS (177170g) using ODT as described above. The con- 
tents of this location should be OOAOAOg. Examine the next 
location (177172o) by using the linefeed key or by typing 
177172 <CR> whicTi should yield either 204g or 2448- For a 
detailed description of register protocol and bit definition, 
refer to Section 4. 

Either diagnostics or an operating system can now be booted. 
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Section 3 
Operation 



3.1 GENERAL INFORMATION 



This section provides the operating instructions for the SDC-RXV21 
controller. Included are bootstrapping, formatting, fill/write, and 
read/empty operations. This sections also reviews operation with an 
RT-11 operating system. 



3 . 2 BOOTSTRAPPING 



If the bootstrap is enabled the SDC-RXV21 will respond to the standard 
bootstrap address 173000. The controller is booted by typing 173000G 
while in console DDT, causing a bus INIT and program execution transfer 
to 173000. An alternate method is to strap the LSI~11 CPU to power up 
in Mode 2, where on power-up, the CPU automatically starts execution 
at 173000. Power-up strapping procedures for the LSI-11 processor 
can be found in the Microcomputer Processors Ha n dbook .* 

To boot either a single or double density diskette, use the following 
procedure: 

1. Place the diskette in drive 0. 

2. If the processor is stapped for power-up Mode 2, operating the 
INIT (boot) switch or cycle DC power OFF and ON. 

3. If the processor is not strapped for power-up Mode 2 while in 
console ODT, type 173000G. 



*Published by Digital Equipment Corporation, Maynard, MA, 1979. 
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3.3 FORMATTING 

The SDC-RXV21 is capable of formatting diskettes in a specified density. 
The formatting is accomplished on two passes. During pass 1, an index 
address mark is written on tack following the index hole. Twenty-six 
sector headers are written following the index address.. Each of the 
remaining 76 tracks is written in the same manner. When track 76 is 
completed, pass 2 is initiated. The controller seeks track and writes 
zero data field in sector 1 using the selected density. The remaining 
sectors are written in the same manner. 

The format command selects diskette density, unit and side (for dual 
drives). Table 3-1 defines the command words. 



DENSITY /SIDE 


UNIT 


UNIT 1 


Single Density Side 
Single Density Side 1 
Double Density Side 
Double Density Side 1 


11 

1011 

411 

1411 


31 

1031 

431 

1431 



TABLE 3-1: DENSITY/SIDE COMMANDS 



Figure 3-1 illustrates a format subroutine. The format command is 
loaded into RXVCS. When TRAN REQ is set, the keyword 222 is loaded 
into RXVDB. When the diskette is formatted a return is made. 



FORMAT: 




MOV //ll, CMD 


; FORMAT 


BIS DENS, CMD 


; DENSITY 


BIS UNIT, CMD 


;UNIT 


BIS SIDE, CMD 


;SIDE 


MOV CMD, @#RXVCS 


; SELECT FUNCTION 


JSR PC, TRWAIT 


;WAIT FOR TR 


MOV nil, @/mXVDB 


;KEYWOIU) 


JSR PC.DNWAIT 


;WAIT FOR DONE 


TST @#RXVCS 


; ERROR 


BMI FRMERR 


;BR IF SO 


RTS PC 




FRMERR : 





FIGURE 3-1 : FORMAT SUBROUTINE 
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Alternately, a diskette can be formatted using console ODT. Open the 
Control and Status (CS) register and deposit the appropriate command. 
Then deposit the format key word, 222, in the Data Buffer (DB) register. 
The following is an example of formatting unit side in double 
density: 



177170 
177172 



004040 
000000 



411 <LF> 
222 <CR> 



3.4 FILL/WRITE OPERATION 



Figure 3-2 illustrates subroutines to write data on a diskette. This 
is done by performing a Fill Buffer operation followed by a Write Sector 
operation. 



FILLBF : 






MOV 


#1, CMD ; 


FILL BUFFER 


BIS 


DENS, CMD ; 


DENSITY 


MOV 


CMD, (a#RXVCS 


SELECT FUNCTION 


JSR 


PC TRWAIT 


WAIT FOR TR 


MOV 


COUNT, (3#RXVDB 


WORD COUNT 


JSR 


PC, TRWAIT 


WAIT FOR TR 


MOV 


#BUFOUT, @//RXVDB 


BUS ADDRESS OF DATA 


JSR 


PC, DNWAIT 


WAIT FOR DONE 


TST 


@//RXVCS 


, ERROR 


BMI 


ERFIL 


;BR IF SO 


RTS 


PC 




ERFIL: 







WSECT : 

MOV 
BIS 
BIS 
BIS 
MOV 
JSR 
MOV 
JSR 
MOV 
JSR 
TST 
BMI 
RTS 

WSERR: 



#5, CMD 


;WRITE, SECTOR 


DENS, CMD 


;DENSITy 


UNIT, CMD 


;UNIT 


SIDE, CMD 


;SIDE 


CMD,(a#RXVCS 


; SELECT FUNCTION 


PC, TRWAIT 


;WAIT FOR TR 


SECTOR, @ym3CVDB 


; SECTOR 


PC TRWAIT 


;WAIT FOR TR 


TRACK (a#RXVDB 


; TRACK 


PC, DNWAIT 


;WAIT FOR DONE 


(a//RXVCS 


; ERROR 


WSERR 


;BR IF SO 


PC 





FIGURE 3-2: WRITE DATA SUBROUTINES 
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3.5 READ /EMPTY OPERATIONS 



Figure 3-3 describes subroutines to read data from a diskette. This 
is done by performing a Read Sector operation, followed by an Empty 
Buffer operation. 



RSECT: 






MOV 


//7, CMD ; 


READ SECTOR 


BIS 


DENS, CMD ; 


DENSITY 


BIS 


UNIT, CMD ; 


UNIT 


BIS 


SIDE, CMD ; 


SIDE 


MOV 


CMD, (3//RXVCS 


SELECT FUNCTION 


JSR 


PC, TRWAIT ; 


WAIT FOR TR 


MOV 


SECTOR, @//RXVDB 


SECTOR 


JSR 


PC, TRWAIT 


WAIT FOR TR 


MOV 


TRACK, @//RXVDB ; 


TRACK 


JSR 


PC, DNWAIT ; 


WAIT FOR DONE 


TST 


(a#RXVCS 


ERROR 


BMI 


RSERRR 


BR IF SO 


RTS 


PC 




RSERR: 






EMPBF: 






MOV 


//3, CMD 


.EMPTY BUFFER 


BIS 


DENS, CMD 


.DENSITY 


MOV 


CMD, (ay/RXVCS 


; SELECT FUNCTION 


JSR 


PC, TRWAIT 


.WAIT FOR TR 


MOV 


COUNT, (a//RXVDB 


WORD COUNT 


JSR 


PC, TRWAIT 


.WAIT FOR TR 


MOV 


//BUFFIN, (?#RXVDB 


;BUS ADDRESS FOR DATA 


JSR 


PC, DNWAIT 


.WAIT FOR DONE 


TST 


@#RXVCS 


; ERROR 


BMI 


EREMP 


;BR IS SO 


RTS 


PC 




EREMP: 







FIGURE 3-3: READ DATA SUBROUTINES 
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3.6 OPERATION USING RT-11 



The SDC-RXV21 controller requires a different handler than the single 
density controllers. This handler is configured to use the DMA trans- 
fer scheme of the controller. Also, diskette density is determined by 
the handler without system intervention, allowing the use of either 
single or double density diskettes interchangeably. 

This handler, designated "DY," is available in RT11-V03B and later 
revisions. 

3.6.1 Creating a DY-Compatible System Disk 

Use the following procedure to create a DY-based system. 

Using an RXOl (or equivalent) system, or a system which has an RXOl 
(or equivalent) peripheral device, copy the monitor file and other 
associated system files onto a single density diskette. These files 
can be obtained from the binary distribution media or by performing a 
SYSGEN and specifying DY as the system device. The following commands 
will initialize the diskette and copy the necessary files to Drive 1.: 

. INIT/NOQUERY DXl : 
.COPY/SYS SYS: SWAP. SYS DXl: 
.COPY/SYS SYS: DYMNXX.SYS DXl: 
.COPY/SYS SYS: TT.SYS DXl: 
.COPY/SYS: DIR.SAV DXl: 
.COPY SYS: PIP.SAV DXl: 
.COPY SYS: DUP.SAV DXl: 

The bootstrap must then be copies from the monitor file to block ^ of 
the diskette. The following command will accomplish this on the diskette 



in drive 1, 



.COPY /BOOT DXl: DYMNXX DXl: 



This diskette can be used with the SDC-RXV21 controller but it is 
single density. To build a double density diskette, first format a 
diskette to double density as explained in Section 3.3. Boot the single 
density system diskette in drive 0, Use the following commands to 
initialize the formatted diskette in drive 1 and copy the system soft- 
ware from drive to drive 1. 

.INIT/NOQUERY DYl : 
.COPY/SYS DY:*.* DYl: 

Finally, copy the bootstrap to block of the diskette in drive 1. 

.COPY /BOOT DYl: DYMNXX DYl: 

The diskette in drive 1 can now be booted as a double density diskette. 
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Section 4 
Programming 



4.1 GENERAL INFORMATION 



This section defines device registers and command protocol for the 
SDC-RXV21. 

Software control of the SDC-RXV21 is performed by means of two device 
registers: the Command and Status (RXVCS) register and a multipurpose 
Data Buffer (RXVDB) register with addresses 177170 and 177172 respec- 
tively. With few exceptions, the registers can be read or write 
using instructions referring to their addresses. 

The RXVCS passes control information from the CPU to the controller 
and reports status and error information from the controller to the 
CPU. The RXVDB provides additional control and status information 
between the CPU and the controller. Information in the RXVDB is a 
function of the controller operation in progress. 

The controller contains a sector buffer capable of storing a complete 
sector. For Read/Write operations the buffer is either filled before 
a Write command or emptied after a Read command under DMA control. 
During a Read the desired sector is located and the sector data are 
transferred to the buffer. 

A detailed description of bit assignments are given for registers: 

177170 



177172 



Command and Status 


RXVCS 


Data Buffer 


RXVDB 


Track Address 


RXVTA 


Sector Address 


RXVSA 


Word Count 


RXVWC 


Bus Address 


RXVBA 


Error and Status 


RXVES 
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4.2 COMMAND AND STATUS REGISTER - RXVCS (177170) 



Functions are initiated by loading the Command and Status register, 
when not busy (bit 5=1), with bit 0=1, 



15 
ERR 



14 13 . 12 
INIT 



EXT 



BIT CODE 
15 ERR 



14 INIT 



ADD RX02 



11 10 9 






8 



DEN 
SEL 



TRAN 
RKQ 



INT 
ENB 



)ONE 



UNIT 
SEL 



2 1 
I 



FIflCT SEL 



GO 



DESCRIPTION 

ERROR. This bit is set by the controller if an error 
occurs during an attempt to execute a command. Cleared 
by INIT or the initiation of a new command. When an 
error is detected the RXVCS is read into the RXVDB. 
Read Only. 

INITIALIZE. This bit, set by the program, initializes 
the controller without initializing all the devices on the 
LSI-11 bus. Write Only. 



CAUTION 



12 
13 



Loading the lower byte of the RXVCS will 
also load the upper byte of the RXVCS. 

When set, the controller will negate DONE and move the 
head position mechanism of drive 1 (if two drives are 
available) to track 0. When completed, the controller 
will repeat the operation on drive 0. The controller 
then clears the Error and Status register, sets Initia- 
lize Done, and Drive Ready if drive is ready. Finally 
the controller reads sector 1, track 1, of drive 0. 

EXT EXTENDED ADDRESS. These bits define an extended bus 
ADD address, bit 12 = MA16, Bit 13 = MA17. Write Only. 



11 RX02 RX02. This bit, asserted by the controller. Indicates an 
RX02-type system. Read Only. 



10 



NOT USED. 



Must be written as a zero. 



HEAD HEAD SELECT. This bit determines the side of the disc 
SEL for execution of the desired function: bit cleared = 
side 0, bit set = side 1. Read/Write. 
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DEN DENSITY SELECT. This bit defines either single or double 
SEL density operation. Bit cleared = single density, bit set 
= double density. Read/Write. 

TRAN TRANSFER REQUEST. This bit Indicates the controller needs 
REQ data or has data available. Read Only. 

INT INTERRUPT ENABLE. This bit, set by the program, enables 
ENB an interrupt when the controller completes an operation 
and asserts DONE. Cleared by INIT. Read/Write. 

DONE DONE. This bit indicates the completion of a function. 
It generates an interrupt when asserted if INT ENB is 
set. Read Only. 



4 


UNIT 




SEL 


3-1 


FNCT 




SEL 



UNIT SELECT. This bit selects one of two discs for execu- 
tion of the desired function. Read/Write. 

These bits define one of eight operations listed below 
and described in detail in Section 4.3. 



GO 



GO. 



000 


Fill Buffer 


001 


Empty Buffer 


010 


Write Sector 


011 


Read Sector 


100 


Set Media Density/Format 


101 


Read Status 


110 


Write Deleted Data Sector 


111 


Read Error Code 


Initiates a 


command to the controller 



Write Only. 



4.3 DATA BUFFER (177172) 



This register is a general purpose data path between the SDC-RXV21 
and the LSI-11. It represents one of six registers (RXVDB, RXVTA, 
RXVSA, RXVWC, RXVBA, and RXVES) . These registers are addressable 
only under the protocal of the function in progress. 

This register is Read/Write if the controller is not in the process 
of executing a command (i.e., it may be manipulated without affecting 
the controller). When the controller is executing a command, this 
register is Read/Write only if RXVCS, bit 7 (TRAN REQ) is set. 
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4.3.1 Data Buffer Register (RXVDB) 

All information transferred to and from the floppy media passes through 
the RXVDB register. 



15 


lA 


13 


12 


11 


10 














^ 



8 


7 


6 


5 


A 


3 


2 


1 























■V — 














. 



READ/ WRITE DATA 



4.3.2 Track Address Reg ister (.RXVTA) 

This register is loaded to indicate on which of the 115g (77 _) tracks 
a given function operates. 



15 


lA 13 12 11 10 9 8 
1 I 1 1 11 


7 


6 


5 


A 


3 


2 


1 





"~r " j-i r- ~ T -r v 


















1 


1 ""T'"! 1 1 ,. 



V 

0-115f 



4.3.3 Sector Address Register (RXVSA) 

This register is loaded to indicate on which of the 32 (26 -) sectors 
a given function operates. 



15 14 13 12 11 10 9 8 7 

-i — \ — h-"1 — ] -t — t-J-— 







,-NOT USED- , , 

J L J 1 .-„.L- I 



"37!«c 



A. 3. A Word C ount Reg is ter (RXyWC) 

This 8-bit register is loaded with the number of words (128 _ maximum) 
to be transferred. At the end of each transfer the Word Count register 
is decremented. When the contents of RXVWC are decremented to zero, 
transfers are terminated, DONE is set (RXVES, bit 5), and, if enabled, 
an interrupt is requested. If the word count is greater than the limit 
for the density specified, the controller asserts WC OVFL (RXVES bit 10). 

15 lA 13 12 11 10 9 8 7 6 5 A3 2 1 

-i — \ — h-i — 1~- h--t- 



-NOT . USED 






0-2008 
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A. 3. 5 Bus Address Register (RXVBA) 

This register is used to generate the bus address, defining the loca- 
tion of data transfer. The register is Incremented after each transfer. 
It will increment across 32K boundary lines via the extended address 
bits in the Control and Status register. Systems with only 16 address 
bits will wraparound to location zero when the extended address bits are 
incremented. 



J5 


U 


13 


12 


11 


10 


9 


8 


7 


6 


5 


4 


3 


2 


1 



































NOT 
USED 






























J 





BUS ADDRESS 



4.3.6 Error an d St atus Regist er (RX VES) 

This register contains the current error and status conditions of the 
drive selected by bit 4, Unit Select, of the RXVCS. The RXVES is 
loaded into the RXVDB upon completion of a function. Read Only. 



15 


14 13 12 
1 


11 


10 


9 


8 


7 


6 


5 


4 


3 


2 


1 





B 


^* 


NXM 


WC 
OVFL 


HEAD 

SEL 


UNIT 
SEL 


DRV 
RDY 


DEL 
DATA 


DRV 
DEN 


DEN 
ERR 


AC 
LO 


INIT 
DONE 


SIDE 
RDY 


CRC 
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NOT USED. 



11 NXM NONEXISTENT MEMORY ERROR. This bit is asserted by the con- 
troller when the memory address specified for a DMA opera- 
tion is nonexistent. 

10 WC WORD COUNT OVERFLOW. This bit indicates that the specified 

OVFL word count is greater than the limit for the density selected, 
When this error is detected the controller terminates the 
fill or empty buffer operation and asserts the Error and 
Done bits. 



HEAD HEAD SELECT. This bit indicates the selected side, 
SEL cleared = side 0, bit set = side 1, 



Bit 



UNIT UNIT SELECT. This bit indicates the selected drive. 
SEL cleared = drive 0, bit set = drive 1, 



Bit 
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tj 


DEL 




DATA 


:5 


DRV 




DEN 




DEN 




ERR 



7 DRV DRIVE READY. This bit is asserted if the selected drive 
RDY exists with proper power, a diskette installed, door 

closed, and a diskette up to speed. This bit is valid 
when retrieved via a Read Status function or at the comple- 
tion of INIT, when it indicates the status of drive 0. 

DELETED DATA. This bit indicates that, during data 
recovery, the identification mark preceding the data 
field was decoded as a deleted data mark. 

DRIVE DENSITY. This bit indicates the density of the 
diskette in the selected drive. Bit cleared « single 
density, bit set = double density. 

DENSITY ERROR. This bit Indicates a density error was 
detected when information was retrieved from the data 
field of the diskette. A density error occurs when the 
density selected dif feres from that of the data field. 
Upon detecting this error the controller loads the RXVES 
into the RXVDB and asserts the Error andDone bits. 

ACLO. This bit, set by the controllers, indicates a 
power failure. 

INITIALIZE DONE. This bit indicates completion of the 
initialize routine, which can be caused by system power 
failure or by programmable LSI-11 bus initialize. 

SIDE READY. This bit is asserted by the controller when a 
double sided drive is selected, is ready, and has double 
sided media inserted. When asserted, this bit indicates 
that side 1 of the selected drive is available for Read 
and Write operations. 

CRC CRC ERROR. This bit indicates a cyclic redundancy check 
error was detected as information was retrieved from a 
data field of the diskette. The information stored in the 
buffer becomes invalid. Upon detection of this error the 
controller loads the RXVES into the RXVDB and asserts the 
Error andDone bits. 



4.4 EXTENDED STATUS REGISTERS 



The SDC-RXV21 controller has four internal status registers. These 
registers provide error information and drive status informtion. 
The registers can be retrieved by a read error code function as 
described In Section 4.8.8. 



3 


AC 




LO 


2 


INIT 




DONE 


1 


SIDE 




RDY 
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4.4.1 Word 1 {7:0) - Definitive Error Code 

OCTAL ERROR CODE DESCRIPTION 

040 Attempt to access a track greater than 76. 

050 Home found before desired track was reached. 

070 Desired sector not found after investigating 52 headers 

(2 revolutions) . 

120 Preamble not found. 

150 Header track address of a good header not comparable with 

the desired track. 

160 Too many tries for an IDAM (Identifies header). 

170 Data AM not found in alloted time. 

200 CRC error on reading the secotr from the disc. 

240 Density Error 

250 Wrong key word for Set Media Density command. 

260 Illegal Data AM. 

270 Invalid POK during write sequence. 

300 Drive not ready. 

310 Drive write protected. 

4.4.2 W ord 1 <fl 5;8> - Not Used 

This register is always cleared by the controller. 

4.4.3 Word 2 QiO) - Current Track Address of Drive 

This register (cleared during INIT to synchronize with actual track 
position) is updated with each Seek on drive and maintains current 
track position. 

4.4.4 Word 2 <^15;8^ - Current Track Address of D riye,J^ 

This register (cleared during INIT to synchronize with actual track 
position) is updated with each Seek on drive 1 and maintains current 
track position. 

4.4.5 Word 3 <"?; o') - Target Track of Current Disc Access 

If legal, the track specified for the last Read/Write command is 
saved in this register. 

4.4.6 Word 3 <15 :0) -Ta rge t Sector of Current Disc Access 

The sector specified for the last Read/Write command is saved in this 
register. 

4.4.7 Word 4 <15;8> -Track Address of Selected Drive 

This register contains the track address read from the sector header 
of the desired sector during the last Read/Write command. 
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4.5 COMMAND PROTO COL 

Data storage and recovery using the SDC-RXV21 controller is accomplished 
by manipulation of the Control and Status (RXVCS) and Data Buffer (RXVDB) 
registers according to the protocol of the individual functions. The 
penalty for violation of protocol can be permannent loss of data. Each 
of the functions are encoded and written into the RXVCS, bits 1-3, as 
described in Section 4.2. The detailed protocol for each function is 
described below. 



4.5.1 Fill Buffer (000 ) 

This function is used to fill the controller buffer with data from the 
host CPU. The host specified the number of words to be transferred. 
The command density bit determines the buffer size (64 or 128 words) . 
The controller zero-fills the remaining buffer space. If the word 
count is too large for the density selected, the function is aborted. 
Error and Done are asserted and the Word Count Overflow bit is set in 
the RXVES. 

The contents of the buffer may be written on the diskette with a sub- 
sequent Write Sector command, or returned to the host CPU using an 
Empty Buffer command. 

VJhen the command is loaded, RXVCS, bit 5 (DONE) is negated. RXVCS, bit 
8, (DEN) must be set to define the buffer size. RXVCS, bits 12 and 
13 (Extended Address) must also be asserted to define the extended 
memory segment used with the buffer address yet to be specified, to 
form the absolute memory address of the data to be transferred. RXVCS, 
bit 4 (UNIT SEL) and bit 9 (HEAD SEL) are ignored since no drive opera- 
tion is required. When RXVCS, bit 7 (TRAN REQ) is first asserted, the 
program must move the word count into the RXVDB, which will negate 
TRAN REQ. 

When the controller again asserts TRAN REQ, the program must move the 
buffer address into the RXVDB. The controller then negates TRAN REQ, 
initiates a DMA cycle, and transfers the first word from the host to 
the controller buffer. At the end of the transfer the Word Count 
register is decremented and the buffer address is incremented by two. 
This cycle is repeated until the Word Count register becomes zero. The 
controller zero-fills the remaining buffer space, set the DONE bit, and 
if enabled, causes an Interrupt Request. After DONE is asserted the 
RXVES is moved into the RXVDB. 

During the data transaction, if any non-existent memory is addressed, 
the controller will time out and abort the function. The ERR and DONE 
bits will be asserted. RXVES, bit 11 (NXM) will be set the the RXVES 
will be moved into the RXVDB. If enabled, an Interrupt Request will be 
generated. 
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4.5.2 Empty Buff er (00 1) 

This operation transfers the contents of the controller to the host 
CPU which specifies the number of words to be transferred. The 
coiranand density bit determines the maximum legal word count. If the 
word count specified is too large for the density selected, the 
function is aborted, ERR and DONE are asserted and the Word Count 
Overflow (WC OVFL) is set in the RXVES . 

The contents of the buffer may be transferred to the host as many 
times as desired or may be written on the diskette with a subsequent 
Write Sector command. Unless a Fill Buffer or Read Sector command is 
issued, the controller buffer is not destroyed. 

When the command is loaded, RXVCS bit 5 (DONE) is negated, and bit 8 
(DEN SEL) must be set to allow the proper word count limit. Bits 12 
and 13 (EXT ADD) must also be asserted to define the extended memory 
segment used with the buffer address (yet to be specified) to form the 
absolute memory destination address. Bit 4 (UNIT SEL) and bit 9 
(HEAD SEL) are ignored since no drive operation is required. When 
bit 7 (TRAN REQ) is first asserted the program moves the word count 
into the RXVDB, which negates TRAN REQ. When TRAN REQ is again asserted 
the program moves the buffer address into the RXVDB. The controller 
then negates TRAN REQ, initiates a DMA, and transfers the first word 
of the buffer to the host. At the end of the transfer, the Word Count 
register is decremented and the Buffer Address register is incremented 
by two. This cycle is repeated until the Word Count register becomes 
zero. * 

During DMA transactions, if any non-existent memory is addressed, the 
controller will time-out and abort the function. An ERR bit will be 
asserted.* 

4.5.3 Write Sector (010) 

The Write Sector function locates a desired track and sector, and writes 
the sector with the contents of the internal sector buffer. When RXVCS 
is loaded with this command, the RXVES is cleared and TRAN REQ and DONE 
are negated. When TRAN REQ is first asserted, the program loads the 
desired sector address into the RXVDB, which negates TRAN REQ. When 
TRAN REQ is again asserted the program loads the desired track address 
into the RXVDB, which negates TRAN REQ. The controller then seeks the 
desired track and sector. The desired track and track field of the 
sector header are compared. If they do not match the operation is 
aborted and ERR is asserted.* 



*DONE is asserted, RXVES is moved into the RXVDB and, if enabled, an 
Interrupt Request will be generated at this point. 
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If the densities agree but the desired sector cannot be located within 
two revolutions, the operation will be aborted and ERR will be asserted.* 

If the desired track and sector are located and the densities agree, 
the contents of the internal sector buffer are written, followed by 
a CRC character in the selected density.* NOTE: The contents of the 
sector buffer are not destroyed by a Write Sector operation. 



CAUTION 

The contents of the internal sector buffer 
are lost during a power failure. However, 
after power is recovered, a Write Sector 
command will cause the random contents of 
the buffer to be written on the diskette 
with a valid CRC character. 

<4.5.4 Rea d Secto r (01 1) 

This function locates the desired track and sector and transfers the 
contents of the data field into the internal sector buffer. When the 
RXVCS is loaded with this command, the RXVES is cleared and the TRAN 
REQ and DONE bits are negated. When TRAN RE:Q is first asserted the 
program loads the desired sector address into the RXVDB, which will 
negate TRAN REQ. When TRAN REQ is again asserted the program loads 
the desired track address into the RXVDB, which will negate TRAN REQ. 

TRAN REQ and DONE bits remain negated while the desired sector is 
located. If after two revolutions the desired sector is not located 
the operation is aborted, and ERR is asserted. 

When the desired sector is located, the desired track and the track 
field of the sector header are compared. If they do not agree, the 
operation is aborted and ERR is asserted. 

If the desired track and sector agree, the data address mark is read 
and diskette density is determined. If the diskette density does not 
compare with the function density, the operation is aborted and ERR 
is asserted. 

If a legal data address mark is located and the densities of the disk- 
ette and function agree, data from the sector is read into the inter- 
nal buffer. If the data address mark indicates a deleted data field, 
RXVES bit 6 (DEL DATA) is set. As data are stored in the Internal 
buffer a CRC is computed and the CRC bytes are recorded. A non-zero 



*DONE is asserted, RXVES is moved into the RXVDB and, if enabled, an 
Interrupt Request will be generated at this point. 
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result indicates a Read Error. When a CRC error is encountered, 
RXVES bit (CRC) is set.* 

If the desired sector is located, the density of the diskette and the 
function agree, and the data are transferred with no CRC error, DONE 
is asserted and, if enabled, an Interrupt Request will be generated. 

A. 5.5 Set Media Density (1 00) 

This dual purpose function can set media density or "reformat" a 
diskette. Media density is set by reqriting all the data address 
marks (single or double density) and writing zero data fields in the 
selected density. "Reformatting" the entire diskette is done by 
writing both the sector headers and the data fields. The data fields 
are written in the selected density preceded by the corresponding 
data address mark. Both commands are initiated by the Set Media 
function but differ in the keyword required to execute the command. 

When the RXVCS is loaded with Set Media Density, the RXVES is cleared 
and DONE is negated. When TRAN REQ is set the program responds with 
a keyword which must be deposited in the RXVDB to complete the proto- 
col. When the controller recognizes this character, it begins exe- 
cuting the command. If an illegal keyword is used, the operation is 
aborted.* 

If the keyword is 111, a Set Media Density operation is asserted. 
This operation starts at track 0, sector 1. Each sector header is 
located and a Write operation is initiated. A data field is written 
with zero data in the selected density. If an error occurs while 
reading any header, the operation is aborted.* If the operation is 
successfully completed, DONE is set and, if enabled, the controller 
asserts an Interrupt Request . 

If the keyword is 222, a Format operation is initiated. This function 
starts at the physical Index of track 0. Each track is written first 
with an index address mark, then 26 sector headers are written sequen- 
tially about the track. When each track is written Set Media Density 
is set as described above. 

The following input string will format the selected unit, in the 
desired density: 

777170 0040A0 XXXX < Lf) 
177172 000000 Z22 <CR> 



*ERR and DONE are asserrted, RXVES is moved into the RXVDB and, if 
enabled, an Interrupt Request will be generated at this point. 
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CAUTION 

— _ J 



Tlie Set Media Density operation takes about 15 
seconds and the Format operation takes about 
A5 seconds. Do not Interrupt these functions. 
If either operation is interrupted, or an error 
occurs, an illegal diskette is gemerated and 
the operation must be repeated. 



4.5.6 Read Status (101) 

This function, initiated by leading the command into the RXVCS, updates 
the drive status information. DONE is negated and IIXVES bit 7 (DR RDY) 
is updated by sampling the drive ready status line. Drive density is 
updated by loading the head of the selected drive and reading the first 
data address mark. This operation requires about 250ms to complete.* 

4.5.7 Write Deleted Data Sector (110) 

This operation is the same as the Write Sector (010) operation except 
that the data address mark preceding the data is not the standard data 
address mark. A single or double density deleted data address mark is 
written according to the density of the function. 

4.5.8 Read Error Code (111) 

This function, initiated by loading the RXVCS with the command, retrieves 
the Extended Status registers. DONE is negated. When TRAN REQ is asserted 
the program loads the bus address into the RXVDB, which negates TRANS REQ. 
Under DMA control one word at a time is assembled and transferred to 
memory starting at the specified address. 

If non-existent memory is encounted during the transfer, the operation 
is aborted, and ERR is asserted.* 

When all four words are transferred DONE is set and, if enabled, an 
Interrupt Request is generated. 



*DONE is asserted, RXVES is moved into the RXVDB and, if enabled, an 
Interrupt Request will be generated at this point. 
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